package com.yeung.swordoffer;

/**
 * 输入一个整数，输出该数二进制表示中1的个数。其中负数用补码表示。
 * <p>
 * Integer.toBinaryString  的负数表示已经是补码
 */
public class 二进制中1的个数 {
    public static void main(String[] args) {
        int number = NumberOf1(-1);
        System.out.println(number);

    }

    public static int NumberOf1(int n) {
        int count = 0;
        //正数
        String code = Integer.toBinaryString(n);
        count = getCount(code.toCharArray());
        return count;
    }

    static int getCount(char[] lines) {
        int count = 0;
        for (char c : lines) {
            if (c == '1') {
                count++;
            }
        }
        return count;
    }
}
